<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>自定义指令</title>
    <script src="../js/vue.js"></script>
    <script src="../js/阻止vue在启动时生成生产提示.js"></script>
</head>

<body>
    <!-- 需求1：定义一个v-big指令，和v-text功能类似，但是会把绑定的数值放大10倍
        需求2：定义一个v-fbind指令，和v-bind功能类似，但是可以让其所绑定的input元素默认获取焦点
     -->
     <div id="root">
         <h2>当前的值是：<span v-text="n"></span></h2>
         <h2>放大10倍后的n值是：<span v-big='n'></span></h2>
         <button @click="n++">点我n+1</button>
     </div>
     <hr>
     <input type="text" v-fbind:value="n">
</body>
<script>
    const vm =new Vue({
        el:'#root',
        data:{
            n:1
        },
        directives:{
            // big函数何时会被调用？1.指令与元素成功绑定时(一上来)2.指令所在的模板被重新解析时
            big(element,binding){
                element.innerText = binding.value*10
            },
            fbind:{
                // 指令与元素成功绑定时(一上来)
                bind(element,binding){
                    element.value = binding.value
                },
                // 指令所在元素被插入页面时
                inserted(element,binding){  
                    element.focus()
                },
                // 指令所在的模板被重新解析时
                updated(element,binding) {
                    element.value = binding.value
                },
            }
        }
    })
</script>

</html>